# LABORATORY MANUAL

SC1005: Digital Logic

# *Lab 2*:

4-bit Adder/Subtractor Circuit with MSI Binary Adder

# COMPUTER ENGINEERING COURSE COMPUTER SCIENCE COURSE

COLLEGE OF COMPUTING AND DATA SCIENCE NANYANG TECHNOLOGICAL UNIVERSITY

### **4-BIT ADDER/SUBTRACTOR CIRCUIT WITH 74LS283**

### 1. OBJECTIVES

- 1.1 To investigate the logic behaviour of the 74LS283 4-bit binary adder integrated circuit.
- 1.2 To build an adder/subtractor circuit using the binary adder IC.
- 1.3 To observe overflow in 2's complement arithmetic.

### 2. LABORATORY

There are two lab venues. A student will go to the same venue for all 5 lab sessions.

Hardware Laboratory 3, N4-B1a-05

Hardware Project Lab, N4-01C-09A

#### 3. EQUIPMENT

### 3.1 Instruments

RDA 2008A Digital-Analog Trainer Digital Oscilloscope Digital Multimeter (DMM)

### 3.2 Components

Component Unit Cost (in S\$ for 100+ devices)

| 74LS283 IC<br>74LS86 IC<br>74LS08 IC<br>74LS32 IC<br>74LS04 IC | 4-bit binary adder Quad two-input exclusive-OR Quad two-input AND Quad two-input OR Hex inverter | 0.75<br>0.45<br>0.45<br>0.45 |
|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------|
| 74LS04 IC                                                      | Hex inverter                                                                                     | 0.45                         |
|                                                                |                                                                                                  |                              |

Updated 2025 Page 1 of 9

#### 4. INTRODUCTION

4.1 In Lab 1, you have implemented a full adder using SSI (small-scale integration) integrated circuit logic components such as AND, OR and XOR.

A full adder is only capable of adding 3 bits together. In most situations, a parallel adder (Figure 1) is needed to add two multi-bit values together. Implementing a parallel adder using SSI components will be too cumbersome and time consuming. Instead, you will implement it using an MSI (medium-scale integration) component 74LS283.

Note: SSI packs up to 10 logic gates into a component; MSI packs up to 100 logic gates into a component.



Figure 1: 4-bit parallel adder comprising 4x full adders

The 74LS283 is a 4-bit binary adder with fast carry. Figure 2 shows its functional block diagram.



Figure 2: 4-bit adder integrated circuit

The 74LS283 device takes in two 4-bit values A and B, a carry input C0, and perform arithmetic addition as follows to produce a 4-bit result  $\Sigma$  and a carry out bit C4. A4, B4 and  $\Sigma$ 4 are the most significant bits.

|   |    | msb |    |    | lsb |
|---|----|-----|----|----|-----|
|   | C4 | ∑4  | Σ3 | ∑2 | ∑1  |
| + |    | B4  | В3 | B2 | B1  |
|   |    | A4  | А3 | A2 | A1  |
|   |    | C3  | C2 | C1 | C0  |

C3, C2 and C1 are the carry bits that would be generated if four separate full adders are used to carry out the addition (e.g. in Figure 1). The 74LS283 integrated circuit does **NOT** provide

Updated 2025 Page 2 of 9

these three carry signals as part of its output. They are included here to provide a clear illustration of the arithmetic addition of multi-bit values.

Example 1: if A=0011, B=0111, C0=1, the addition will be:

|   |   | 1 | 1 | 1 | 1 |
|---|---|---|---|---|---|
|   |   | 0 | 0 | 1 | 1 |
| + |   | 0 | 1 | 1 | 1 |
|   | 0 | 1 | 0 | 1 | 1 |

Example 2: if A=1011, B=0111, C0=0, then the addition will be:

|   |   | 1 | 1 | 1 | 0 |
|---|---|---|---|---|---|
|   |   | 1 | 0 | 1 | 1 |
| + |   | 0 | 1 | 1 | 1 |
|   | 1 | 0 | 0 | 1 | 0 |

4.2 The 74LS283 device merely adds a pair of binary values. The interpretation of the values are determined by the **human** user, not by the device.

In the two examples above, the decimal equivalent of the values depend on the number representation adopted by the human. This is illustrated in Table 1.

Table 1

|               | Human interpretation of values |                   |  |  |  |
|---------------|--------------------------------|-------------------|--|--|--|
| Binary values | Unsigned decimal               | Signed decimal in |  |  |  |
|               |                                | two's complement  |  |  |  |
|               |                                | representation    |  |  |  |
| Example 1     |                                |                   |  |  |  |
| C0=1          | 1                              | 1                 |  |  |  |
| A=0011        | 3                              | +3                |  |  |  |
| B=0111        | 7                              | +7                |  |  |  |
| ∑=1011        | 11                             | -5                |  |  |  |
| C4=0          | 0                              | C4 is ignored     |  |  |  |
|               |                                | Note: overflow    |  |  |  |
|               |                                |                   |  |  |  |
| Example 2     |                                |                   |  |  |  |
| C0=0          | 0                              | 0                 |  |  |  |
| A=1011        | 11                             | -5                |  |  |  |
| B=0111        | 7                              | +7                |  |  |  |
| Σ=0010        | 2                              | +2                |  |  |  |
| C4=1          | 16                             | C4 is ignored     |  |  |  |
|               | Note: C4 has value             |                   |  |  |  |

4.3 In 2's complement arithmetic, the **subtraction** X-Y can be evaluated by X + (2's complement of Y). The 2's complement of Y can be obtained by inverting every bit of Y (i.e. 1's complement of Y) and add 1.

Updated 2025 Page 3 of 9

Example 3: if X=1000, Y=1101, X-Y is performed as such:

|   |   | 0 | 0 | 0 | 1 | C0=1                  |
|---|---|---|---|---|---|-----------------------|
|   |   | 1 | 0 | 0 | 0 |                       |
| + |   | 0 | 0 | 1 | 0 | (1's complement of Y) |
|   | 0 | 1 | 0 | 1 | 1 |                       |

In this example, the signed decimal interpretation is: -8 - (-3) = -5

4.4 In Lab 2, you will use the 74LS283 to implement a circuit that can perform two's complement addition/subtraction. Refer to the device datasheet to note down the pin number for each input and output. Verify them against Table 2.

Table 2: 74LS283 pinouts

| Pin function  | Pin name                                  | 74LS283 pin number |
|---------------|-------------------------------------------|--------------------|
| Power supply  | Vcc                                       | 16                 |
| Ground        | Gnd                                       | 8                  |
| Carry input   | C0                                        | 7                  |
| 4-bit operand | A4, A3, A2, A1                            | 12, 14, 3, 5       |
| 4-bit operand | B4, B3, B2, B1                            | 11, 15, 2, 6       |
| Sum output    | $\sum 4$ , $\sum 3$ , $\sum 2$ , $\sum 1$ | 10, 13, 1, 4       |
| Carry output  | C4                                        | 9                  |

4.5 In two's complement arithmetic, **overflow** may occur in some cases. This happens when the result falls outside the range of values that can be represented given the number of bits.

Given n bits, the range of signed decimal values that can be represented in two's complement is:

$$\{-(2^{n-1}), 2^{n-1}-1\}$$

For example, if n=8, the range will be -128 to +127. Adding +98 with +99 will produce a result of +197 which cannot be represented in 8 bits. This means there is an overflow.

Arithmetic overflow can be easily detected by comparing the sign of the operands with the sign of the arithmetic result. Refer to example 1 in Table 1. When +3 is added with +7 as well as a carry input, the expected result is +11. Since the largest value that can be represented in 4 bits is +7, this is oviously a case of overflow. This can be seen from the binary result  $\Sigma$ =1011, which shows the sign bit as 1, contradicting with the positive sign bit of the two operands +3 and +7.

Since both subtraction and addition are performed as <u>addition</u> in the adder/subtractor circuit, the **same method** for overflow detection is used regardless whether the circuit performs X+Y or X-Y (which is essentially X+Y'+1).

Updated 2025 Page 4 of 9

#### 5. PROCEDURE

#### 5.1 4-BIT BINARY ADDER

5.1.1 Figure 3 shows the circuit setup. Refer to steps 1-6 of *Lab 2 circuit connection guide.pdf* for a pictorial guide.

Mount one unit of the 74LS283 device on the breadboard. Connect its Vcc to 5V and Gnd to 0V. Connect one toggle switch to <u>each</u> of the inputs A4, A3, A2, A1, B4, B3, B2, B1 and C0. Connect one LED to each of the outputs  $\sum 4$ ,  $\sum 3$ ,  $\sum 2$ ,  $\sum 1$  and C4. Refer to Lab 2 Circuit connection guide.pdf (steps 1 – 6).

Be very careful in connecting the switches/LEDs in the correct physical order (msb on the left, lsb on the right) so that it is easier for you to observe the input and output values.



Figure 3: 4-bit binary adder with toggle switches and LEDs connected

5.1.2 Power up the circuit and check that it is adding correctly. Table 3 shows the values from the three examples in Section 4 that you may use to verify the results.

|          | Inputs |      |    | Outputs |      |  |
|----------|--------|------|----|---------|------|--|
| Examples | Α      | В    | C0 | C4      | Σ    |  |
| 1        | 0011   | 0111 | 1  | 0       | 1011 |  |
| 2        | 1011   | 0111 | 0  | 1       | 0010 |  |
| 3        | 1000   | 0010 | 1  | 0       | 1011 |  |
| 4        | 0101   | 1010 | 1  |         |      |  |
| 5        | 1110   | 1001 | 1  |         |      |  |

Table 3

Determine the output values of examples 4 & 5 in Table 3.

Pause and think: What is the largest binary result that can be obtained from this circuit? What is its decimal equivalent assuming unsigned representation is used?

Assessment (a): student to demonstrate addition circuit

Updated 2025 Page 5 of 9

### 5.2 4-BIT 2'S COMPLEMENT ADDITION/SUBTRACTION CIRCUIT

5.2.1 Modify the circuit you have built in section 5.1 such that it can perform 2's complement addition (X+Y) and subtraction (X-Y), as shown in Figure 4. For your convenience, the pin numbers on the 74LS283 adder and the 7486 quad-XOR are included.



Figure 4: 4-bit adder/subtractor circuit

- 5.2.2 Mount a 74LS86 IC (quad XOR) on the circuit board and connect its Vcc (pin 14) and GND (pin 7) to 5V and 0V respectively..
- 5.2.3 Connect the circuit using the information from Figure 4. Take care to connect it correctly, otherwise you will need to spend far more time on figuring out why it does not work.
- 5.2.4 Power up the circuit and check that it is adding and subtracting correctly.

Pause and think: What purpose do the XOR gates serve? What should be the correct logic level (0 or 1) at the input Add/Sub for addition and subtraction, respectively?

Toggle the switches to vary the inputs (x, y, Add/Sub) and observe the corresponding outputs on the LEDs. Verify that the circuit is correct by using the test cases in Table 4. Calculate the expected results. Are the observed results same as what you have expected? Are you able to determine the overflow cases?

Updated 2025 Page 6 of 9

Table 4

| Test case | x +/- y   | Calculated | Observed    | C4 | Overflow |
|-----------|-----------|------------|-------------|----|----------|
|           |           | Sum        | S3 S2 S1 S0 |    | (Y/N)    |
| 1         | 0101+0001 | 0110       |             | 0  | N        |
| 2         | 0101-0001 | 0100       |             | 1  | N        |
| 3         | 0001-0101 |            |             |    |          |
| 4         | 1111-0001 |            |             |    |          |
| 5         | 0101+0100 |            |             |    |          |
| 6         | 1011-0101 |            |             |    |          |
| 7         | 1011-1000 |            |             |    |          |
| 8         | 1011+1000 |            |             |    |          |

Assessment (b): student to demonstrate addition/subtraction circuit

#### 5.3 IMPLEMENTATION OF AN OVERFLOW BIT (OPTIONAL)

Attempt this only if you have completed and understood 5.1 and 5.2.

5.3.1 Obtain a Boolean expression for output V, such that V=1 when there is an overflow in the result of the add/subtractor circuit in section 5.2. V=0 when there is no overflow.

**Hint:** both subtraction and addition are performed as addition by the circuit. If the sign bits A4 and B4 are the same, but different from S3, then it is a clear indication of overflow. You may make use of XOR to compare two bits.

- 5.3.2 Implement the Boolean expression of V obtained in 5.3.1. Connect output V to an LED. Additional logic components are available for the implementation.
- 5.3.3 Power up the circuit and check that the overflow bit is working correctly by comparing with the entries made earlier in Table 4.
- 5.3.4 Pause and think: Is V = C4? Why?

#### 6. PREPARATION AND OBSERVATIONS

Maintain proper records of your preparation (e.g. circuit connection diagram for the 74LS86 IC) and observations (e.g. truth tables).

#### 7. LAB ASSESSMENT AND QUIZ

Each student is required to demonstrate the completion of sections **5.1 and 5.2** to the lab instructor.

There will be a 10-minute written lab quiz at the end of this lab session. The quiz will include (but not limited to) concepts, components, equipment and observations covered in this lab session.

Updated 2025 Page 7 of 9

### 8. REFERENCES

8.1 SC1005 Digital Logic Supplementary Laboratory Manual – Wiring & Troubleshooting Digital Circuits, Digital Logic Couse Site, <u>NTULearn</u>.

- 8.2 SC1005 Lab 2 circuit connection guide.pdf, Digital Logic Couse Site, NTULearn.
- 8.3 <a href="https://byjus.com/boolean-algebra-calculator/">https://byjus.com/boolean-algebra-calculator/</a> (free online tool)

Updated 2025 Page 8 of 9

### **Appendix**

# Pin assignments (from TI Digital Logic Pocket Data Book 2003)

# Follow the pinouts when connecting up a logic component



Updated 2025 Page 9 of 9